# Displaying Characters on an LCD Character Module

### I. Introduction:

This application note describes a simple technique to display characters from both the internal character generator and user designed characters on an LCD character module. The controlling microcontroller is a Phillips 87C751, a derivitive of the popular Intel 8051. The LCD module is connected to the microcontroller through its I/O ports. It could also be connected directly to the data bus with the addition of address decoding logic.

The process of displaying character to this module is divided into three steps. First the module must be initialized. This sets up the built-in LCD controller chip. Second, some user designed characters are uploaded to the CGRAM. This allows the displaying of up to 8 custom characters in addition to the 192 character permanently stored in the module. Lastly, a message consisting of a mix of standard ASCII characters and custom designed characters is displayed on the module.

### II. Circuit Schematic



**Crystal Clear and Visibly Superior LCD Modules** 

## **III. Software Flowchart:**



## Crystal Clear and Visibly Superior LCD Modules

| ******             |                       | *****                                   |              | ****                                      |                                                       |                                                          |                            | - 4 #00b                                            |                                                                   |  |  |  |
|--------------------|-----------------------|-----------------------------------------|--------------|-------------------------------------------|-------------------------------------------------------|----------------------------------------------------------|----------------------------|-----------------------------------------------------|-------------------------------------------------------------------|--|--|--|
| ;                  | Application           |                                         |              |                                           |                                                       |                                                          | mov<br>acall               | p1,#38h<br>command_byte                             |                                                                   |  |  |  |
| ;                  |                       | ======<br>g Charact                     |              | LCD Character Module                      |                                                       |                                                          | acall                      | ddelay                                              | ;initial delay 4.1mSec                                            |  |  |  |
| ;                  | Description Controlle | on:                                     |              |                                           |                                                       |                                                          | mov<br>mov<br>mov<br>acall | RTL,#D100l<br>RTH,#D100h<br>p1,#38h<br>command_byte | ;set timer reload value<br>;dealy time = 100uSec<br>;function set |  |  |  |
| ;                  |                       | CD controller: HD44780, KS0066, SED1278 |              |                                           |                                                       |                                                          | acall                      | ddelay                                              | ;busy flag not avail. yet                                         |  |  |  |
| .*******<br>,      |                       |                                         |              | *****                                     |                                                       |                                                          | mov                        | p1,#38h                                             | ;function set                                                     |  |  |  |
| .******            |                       | Definition<br>*****                     |              | *****                                     |                                                       |                                                          | acall<br>mov               | command_byte<br>p1,#0ch                             | ;display on                                                       |  |  |  |
| ,<br>EnableT0      | )                     | equ                                     | 082h         | ;enable timer0                            |                                                       |                                                          | acall                      | command_byte                                        | uispiay on                                                        |  |  |  |
| Disable            |                       | equ                                     | 000h         | ;disable timer                            |                                                       |                                                          | mov                        | p1,#01h                                             | ;clear display                                                    |  |  |  |
| D4100h             |                       | equ                                     | 00ch         | ;timer reload high byte def.              |                                                       |                                                          | acall                      | command_byte                                        |                                                                   |  |  |  |
| D4100I             |                       | equ                                     | 003h         | ;timer reload = 4.1mSec.                  |                                                       |                                                          |                            |                                                     |                                                                   |  |  |  |
| D100h<br>D100l     |                       | equ                                     | 000h<br>04ch | ;timer reload<br>:timer reload = 100uSec. |                                                       |                                                          | acall                      | cgram<br>first_line                                 | ;define custom fonts                                              |  |  |  |
|                    | *****                 | equ<br>*******                          |              | ,umer reload = 100dSec.                   |                                                       |                                                          | acall<br>acall             | second_line                                         | ;display first line<br>;display second line                       |  |  |  |
| ;                  | Ram Def               | inition                                 |              |                                           |                                                       | sdone:                                                   | aoan                       | occoria_iiric                                       | , alopiay occoria line                                            |  |  |  |
| ,<br>.*******      | ******                | ******                                  | ******       |                                           |                                                       |                                                          | setb                       | IDLE                                                | ;power down mode                                                  |  |  |  |
| Flags              |                       | DATA                                    | 020h         | ;flag                                     |                                                       |                                                          | jmp                        | sdone                                               | •                                                                 |  |  |  |
| TstFlag            |                       | BIT                                     | Flags.0      | ;interrupt flag bit                       |                                                       |                                                          |                            |                                                     |                                                                   |  |  |  |
| .*******<br>,      | ******                |                                         | ******       |                                           |                                                       | .**************************************                  |                            |                                                     |                                                                   |  |  |  |
| ;                  | Port Con              |                                         |              |                                           |                                                       | ;Subroutine: WRITE<br>:=============                     |                            |                                                     |                                                                   |  |  |  |
|                    | P1.0 -> D             | ======<br>)()                           | ===          |                                           |                                                       | •                                                        |                            |                                                     | rtes to the LCD module                                            |  |  |  |
| ;                  | P1.1 -> D1            |                                         |              |                                           |                                                       | ;Parameters:dptr = should be set to the beginning of     |                            |                                                     |                                                                   |  |  |  |
| ;                  | P1.2 -> D             | )2                                      |              |                                           |                                                       | ;                                                        | •                          |                                                     | byte address                                                      |  |  |  |
| ;                  |                       |                                         |              |                                           |                                                       | ;                                                        |                            | Data bytes should                                   | be finished with 99H                                              |  |  |  |
| ;                  | P1.7 -> D             |                                         |              |                                           |                                                       | ;Alg:                                                    | te                         |                                                     |                                                                   |  |  |  |
| ;                  | P3.0 -> Enable        |                                         |              |                                           | ; while (new data != 99h) { ; set port1 with new data |                                                          |                            |                                                     |                                                                   |  |  |  |
| ;                  | P3.1 -> RS            |                                         |              |                                           |                                                       |                                                          |                            |                                                     |                                                                   |  |  |  |
| ·<br>·<br>·******* | ; P3.2 -> RW          |                                         |              |                                           |                                                       |                                                          |                            | call data_byte<br>increment data po                 | intor                                                             |  |  |  |
| ,                  | Interrupt             | Vectors                                 |              |                                           |                                                       |                                                          |                            | liicrement data po                                  | inter                                                             |  |  |  |
| ;                  |                       |                                         |              |                                           |                                                       |                                                          | return                     | J                                                   |                                                                   |  |  |  |
| ,                  | org                   | 000h                                    |              |                                           |                                                       | ,<br>.*******<br>,                                       |                            | *******                                             | ******                                                            |  |  |  |
|                    | jmp                   | PowerUp                                 | )            | ; Power up reset vector                   |                                                       | write:                                                   |                            |                                                     |                                                                   |  |  |  |
|                    | org                   | 003h                                    |              |                                           |                                                       | write_loc                                                | p:                         |                                                     |                                                                   |  |  |  |
|                    | jmp                   | ExInt0                                  |              | ; External interrupt 0 vector             |                                                       |                                                          | mov                        | a,#0                                                |                                                                   |  |  |  |
|                    | org                   | 00bh                                    |              |                                           |                                                       |                                                          | movc                       | a,@a+dptr                                           |                                                                   |  |  |  |
|                    | jmp                   | Timer0                                  |              | ; Counter/ Timer 0 int vector             | •                                                     |                                                          | cjne                       | a,#99h,write_cont                                   |                                                                   |  |  |  |
|                    | org                   | 013h                                    |              | . External int 4 vector                   |                                                       |                                                          | ret                        |                                                     |                                                                   |  |  |  |
|                    | jmp                   | ExInt1<br>01bh                          |              | ; External int 1 vector                   |                                                       | write_co                                                 |                            | p1,a                                                |                                                                   |  |  |  |
|                    | org<br>jmp            | Timer1                                  |              | ; Timer 1 int vector                      |                                                       |                                                          | mov<br>acall               | data_byte                                           |                                                                   |  |  |  |
|                    | org                   | 023h                                    |              | , Timer Time vector                       |                                                       |                                                          | inc                        | dptr                                                |                                                                   |  |  |  |
|                    | jmp                   | I2C                                     |              | ; I2C serial int vector                   |                                                       |                                                          | jmp                        | write_loop                                          |                                                                   |  |  |  |
|                    |                       |                                         |              |                                           |                                                       |                                                          |                            |                                                     |                                                                   |  |  |  |
|                    | org                   | 50h                                     |              |                                           |                                                       | .*******<br>,                                            |                            | *********                                           | ****                                                              |  |  |  |
| PowerUp            |                       |                                         |              |                                           |                                                       | ; Delay Routine:<br>; Delay periond = 4/3uSec * DefRth,I |                            |                                                     |                                                                   |  |  |  |
| ,                  |                       |                                         | reparation   |                                           |                                                       | .*****                                                   |                            | eriona = 4/3u5ec " D                                |                                                                   |  |  |  |
|                    | clr<br>clr            | TR<br>TF                                |              | ;disable timer<br>;clear overflow         |                                                       | ddolov:                                                  |                            |                                                     |                                                                   |  |  |  |
| .*****             | *********             |                                         | *****        | ,clear overnow                            |                                                       | ddelay:                                                  | setb                       | TR                                                  | ;start timer                                                      |  |  |  |
| ;                  | LCD Initia            | alization R                             | outine       |                                           |                                                       |                                                          | mov                        | IE,#EnableT0                                        | ;enable timer                                                     |  |  |  |
| ,<br>.*******      |                       | ******                                  |              |                                           |                                                       |                                                          | clr                        | TstFlag                                             | ;reset flag                                                       |  |  |  |
| cinit:             | clr                   | P3.1                                    |              | ;RS low                                   |                                                       | dloop:                                                   | jnb                        | TstFlag,dloop                                       | J                                                                 |  |  |  |
|                    | clr                   | P3.2                                    |              | ;RW low                                   |                                                       | -                                                        | ret                        |                                                     |                                                                   |  |  |  |
|                    | setb                  | P3.0                                    |              | ;Enable                                   |                                                       | .*******<br>,                                            |                            | *****                                               |                                                                   |  |  |  |
|                    |                       |                                         |              |                                           |                                                       | ;                                                        |                            | ess to beginning                                    |                                                                   |  |  |  |
|                    | mov                   | RTL,#D4                                 |              | ;set timer reload value                   |                                                       | ,<br>.******                                             | of CG R                    |                                                     |                                                                   |  |  |  |
|                    | mov                   | RTH,#D4                                 | 1100h        | ;dealy time = 4.1mSec                     |                                                       | ,                                                        |                            |                                                     |                                                                   |  |  |  |



## **Application Note**

### **Crystal Clear and Visibly Superior LCD Modules**

| cgram:        |                                                    |                           |                                |  |  |  |  |  |  |
|---------------|----------------------------------------------------|---------------------------|--------------------------------|--|--|--|--|--|--|
|               | mov                                                | p1,#40h                   |                                |  |  |  |  |  |  |
|               | acall                                              | command_byte              |                                |  |  |  |  |  |  |
|               | mov                                                | dptr,#cgram_data<br>write |                                |  |  |  |  |  |  |
|               | acall<br>ret                                       | write                     |                                |  |  |  |  |  |  |
| .******       | ******                                             | *****                     |                                |  |  |  |  |  |  |
| ,             | Set DDR                                            | AM to the beginnig o      | of                             |  |  |  |  |  |  |
| ;             | the first I                                        |                           | •                              |  |  |  |  |  |  |
| .*******      | ******                                             | ******                    |                                |  |  |  |  |  |  |
| first_line    |                                                    |                           |                                |  |  |  |  |  |  |
|               | mov                                                | p1,#080h ;set DDR         | RAM                            |  |  |  |  |  |  |
|               | acall                                              | command_byte              |                                |  |  |  |  |  |  |
|               | mov                                                | dptr,#fline_data          |                                |  |  |  |  |  |  |
|               |                                                    | write                     |                                |  |  |  |  |  |  |
| .******       | ret<br>************************************        |                           |                                |  |  |  |  |  |  |
| ,             |                                                    |                           | of                             |  |  |  |  |  |  |
|               | Set DDRAM to the beginning of the second line - 40 |                           |                                |  |  |  |  |  |  |
| ,<br>.******  | ******                                             |                           |                                |  |  |  |  |  |  |
| second_       | line:                                              |                           |                                |  |  |  |  |  |  |
|               | mov                                                | p1,#0c0h ;set DDR         | RAM                            |  |  |  |  |  |  |
|               | acall                                              | command_byte              |                                |  |  |  |  |  |  |
|               | mov                                                | dptr,#sline_data          |                                |  |  |  |  |  |  |
|               | acall                                              | write                     |                                |  |  |  |  |  |  |
| *****         | ret                                                | ******                    | ****                           |  |  |  |  |  |  |
| ,             |                                                    |                           |                                |  |  |  |  |  |  |
| ,<br>.******  |                                                    | mmand/Data to the l       |                                |  |  |  |  |  |  |
| ,<br>comman   | d byte:                                            |                           |                                |  |  |  |  |  |  |
|               | clr                                                | p3.1                      | ; RS low for a command byte.   |  |  |  |  |  |  |
|               | jmp                                                | bdelay                    | •                              |  |  |  |  |  |  |
| data_byt      | e:                                                 |                           |                                |  |  |  |  |  |  |
|               | setb                                               | p3.1                      | ; RS high for a data byte.     |  |  |  |  |  |  |
|               | nop                                                |                           |                                |  |  |  |  |  |  |
| bdelay:       |                                                    |                           | 5/ 1 / " 1                     |  |  |  |  |  |  |
|               | clr                                                | p3.2                      | ; R/w low for a write mode     |  |  |  |  |  |  |
|               | clr<br>nop                                         | p3.0                      |                                |  |  |  |  |  |  |
|               | setb                                               | p3.0                      | ;enable pulse                  |  |  |  |  |  |  |
|               | nop                                                | p0.0                      | ,eaz.e pa.ee                   |  |  |  |  |  |  |
| .******       |                                                    | Check Busy Flag           |                                |  |  |  |  |  |  |
|               | mov                                                |                           | e port1 to input mode          |  |  |  |  |  |  |
|               | setb                                               | p3.2                      | ;set RW to read                |  |  |  |  |  |  |
|               | clr                                                | p3.1                      | ;set RS to command             |  |  |  |  |  |  |
|               | clr                                                | p3.0                      | generate enable pulse;         |  |  |  |  |  |  |
|               | nop                                                | n2 0                      |                                |  |  |  |  |  |  |
| bloop:        | setb                                               | p3.0                      |                                |  |  |  |  |  |  |
| bloop:        | nop<br>mov                                         | a,p1                      |                                |  |  |  |  |  |  |
|               | anl                                                | a,#80h                    | ;check bit#7 busy flag         |  |  |  |  |  |  |
|               | cjne                                               | •                         | waiting until busy flag clears |  |  |  |  |  |  |
| .*******      |                                                    | ******                    | 9                              |  |  |  |  |  |  |
| ;             | check bu                                           | ısy flag twice            |                                |  |  |  |  |  |  |
| .*******<br>, | ******                                             | ******                    |                                |  |  |  |  |  |  |
| bwait:        |                                                    |                           |                                |  |  |  |  |  |  |
|               | mov                                                | a,p1                      |                                |  |  |  |  |  |  |
|               | anl                                                | a,#80h                    |                                |  |  |  |  |  |  |
|               | cjne                                               | a,#00h,bloop              |                                |  |  |  |  |  |  |
|               | clr<br>ret                                         | p3.2                      | return to write mode           |  |  |  |  |  |  |
| .******       | ret<br>*******                                     | ******                    |                                |  |  |  |  |  |  |
| ;             | ,<br>; Interrupt Routines                          |                           |                                |  |  |  |  |  |  |
| ,<br>.******  |                                                    | ******                    |                                |  |  |  |  |  |  |
| ExInt0:       |                                                    |                           |                                |  |  |  |  |  |  |
|               |                                                    |                           |                                |  |  |  |  |  |  |

```
ExInt1:
Timer1:
I2C:
         reti
        **********
Timer0:
         setb
                  TstFlag
         clr
                  TR
                  IE,#Disable
         mov
         reti
         Data Bytes
FLINE_DATA:
         db
                  '>>> HANTRONIX <<<'
         db
                  099h
SLINE_DATA:
                  00h,01h,02h,03h,04h,05h,06h,07h
         db
         db
CGRAM DATA:
                  0ah,15h,11h,11h,0ah,04h,00h,00h
font1:
         db
                  04h,0ah,11h,11h,15h,0ah,00h,00h
         db
font2:
         db
                  04h,0eh,15h,04h,04h,04h,04h,00h
font3:
font4:
         db
                  04h,04h,04h,04h,15h,0eh,04h,00h
font5:
         db
                  18h,18h,1fh,1fh,1fh,18h,18h,00h
                  1fh,1fh,03h,03h,03h,1fh,1fh,00h
font6:
         db
                  0ah,15h,0ah,15h,0ah,15h,0ah,00h
font7:
         db
                  15h,0ah,15h,0ah,15h,0ah,15h,00h
font8:
         db
         db
         end
```

\*Display on a 16x2 Character Module



\* Display Character Position and DDRAM Address of a 16x2 Character Module.

|                | 1  | 2  | 3  | 4  | Display Position | 14 | 15 | 16 |
|----------------|----|----|----|----|------------------|----|----|----|
| First<br>Line  | 00 | 01 | 02 | 03 |                  | 0D | 0E | 0F |
| Second<br>Line | 40 | 41 | 42 | 43 |                  | 4D | 4E | 4F |
|                |    |    | 1  |    | DDRAM Address    |    |    |    |



BITS 5,6,&7 NOT USED

<sup>\*</sup> Custom characters memory map.